

Hello, and welcome to this presentation of the STM32 I<sup>2</sup>C interface. It covers the main features of this communication interface, which is widely used to connect devices such as microcontrollers, sensors, and serial interface memories.



The I<sup>2</sup>C interface is compliant with the NXP I<sup>2</sup>C-bus specification and user manual, Revision 5; the SMBus System Management Bus Specification, Revision 3; and the PMBus Power System Management Protocol Specification, Revision 1.3.

This peripheral provides an easy-to-use interface, with very simple software programming, and full timing flexibility. Additionally, the I<sup>2</sup>C peripheral is functional in low-power stop modes.



The I<sup>2</sup>C peripheral supports multi-master and slave modes. The I<sup>2</sup>C IO pins must be configured in open-drain mode. The logic high level is driven by an external pull-up. The IO pins support the 20 mA output drive required for Fast mode Plus. The peripheral controls all I<sup>2</sup>C bus-specific sequencing, protocol, arbitration and timing values.

7- and 10-bit addressing modes are supported, and multiple 7-bit addresses can be supported in the same application. The peripheral in master mode supports slave clock stretching and clock stretching from slave side. In slave mode configuration of the peripheral, the clock stretching can be disabled by software.

## Key features 4

- Programmable setup and hold times
- Programmable analog and digital noise filters on SCL and SDA lines
- Wakeup from Stop mode on address match
- Independent clock allowing communication baud rate independent from system clock



The Setup and Hold times are programmable by software. Analog and digital glitch filters on the data and clock lines can be configured by software.

The peripheral can wake up the MCU from Stop mode when an address match is detected.

The peripheral has an independent clock domain, which allows a communication baud rate independent from the system clock.



Here is the I<sup>2</sup>C block diagram. The registers are accessed through the APB bus, and the peripheral is clocked with the I<sup>2</sup>C clock, which is independent from the APB clock. The I<sup>2</sup>C clock can be selected from among the system clock (SYSCLK), the high speed internal 16 MHz RC oscillator clock (HSI16) and the APB1 clock (PCLK1). Analog and digital noise filters are present on the SCL and SDA lines. A 20 mA driving capability is enabled using the control bits in the System configuration registers. In addition, an SMBus Alert pin is available in SMBus mode.

## I<sup>2</sup>C programmable timings

#### Full flexibility in timing generation

- Setup and hold times between SDA and SCL lines during transmission are programmable through the PRESC, SDADEL and SCLDEL fields in the I<sup>2</sup>C Timing Register (I2C\_TIMINGR).
  - SDADEL is used to generate Data Hold time. t<sub>SDADEL</sub> = [SDADEL \* (PRESC+1) + 1] \* t<sub>I2CCLK</sub>
  - SCLDEL is used to generate Data Setup time. t<sub>SCLDEL</sub> = (SCLDEL+1) \* (PRESC+1) \* t<sub>I2CCLK</sub>





The I<sup>2</sup>C setup and hold times can be configured by software through the I<sup>2</sup>C Timing register.

The SDADEL and SCLDEL counters are used during transmission, in order to guarantee the minimum Data Hold and Data Setup times.

The I<sup>2</sup>C peripheral waits for the programmed Data Hold time after detecting a falling edge on the clock line before sending the data. After the data is sent, the clock line is stretched low during the programmed Data Setup time.

The total Data Hold time is greater than the programmed SDADEL counter. This is due to the fact that SDADEL delay is only added once the SCL falling edge is internally detected. The time (t<sub>SYNC1</sub>) needed for this internal detection depends on the SCL falling edge, the input delay due to the filters, and the delay due to the internal SCL synchronization with the I<sup>2</sup>C clock . However, the setup time is not impacted by these internal delays.

# I<sup>2</sup>C master clock generation -

### Full flexibility in master clock generation

- SCL Low and High duration programmable through I2C\_TIMINGR
  - SCL Low counter: (SCLL+1) \* (PRESC+1) \* t<sub>I2CCLK</sub>
    - · Starts counting after internal detection of the falling edge of SCL.
    - · After the count, SCL is released.
  - SCL High counter: (SCLH+1) \* (PRESC+1) \* t<sub>I2CCLK</sub>
    - · Starts counting after internal detection of the rising edge of SCL.
    - · After the count, SCL is driven low.
- SCL period = t<sub>SYNC1</sub> + t<sub>SYNC2</sub> + [(SCLL+1) + (SCLH+1)] \* (PRESC+1) \* t<sub>I2CCLK</sub>





The I<sup>2</sup>C master clock's low- and high-level durations are configured by software in the I<sup>2</sup>C Timings register.

The SCL low- and high-level counters start after the detection of the edge of the SCL line. This implementation allows the peripheral to support the master clock synchronization mechanism in a multi-master environment as well as the slave clock stretching feature.

Therefore, the total SCL period is greater than the sum of the counters. This is linked to the added delays due to the internal detection of the SCL line edge. These delays,  $t_{SYNC1}$  and  $t_{SYNC2}$ , depend on the SCL falling or rising edge, the input delay due to the filters, and the delay due to the internal SCL synchronization with the I2C clock.

The rising edge depends on pull-up resistor and SCL line capacitance. The falling edge depends on the I/O port parameters defined in the datasheet. In order to properly configure clock speed, these edges can be either measured or calculated. They are needed in order to properly configure I<sup>2</sup>C peripheral in the STM32CubeMX tool, then the settings of the Timing Register can be automatically calculated by this tool.

# Slave addressing mode

#### Large number of slave addresses

- I<sup>2</sup>C can acknowledge several slave addresses. 2 address registers:
  - I2C\_OAR1: 7- or 10-bit mode.
  - I2C\_OAR2: 7-bit mode only. OA2MSK[2:0] allow masking of 0 to 7 LSBs of OAR2

| OA2MSK[2:0] | Address match condition                                     |
|-------------|-------------------------------------------------------------|
| 000         | Address[7:1] = CA[7:1]                                      |
| 001         | Address[72] = CA[7:2] (bit 1 is don't care)                 |
| 010         | Address[7:3] = CA[7:3] (bits 2:1 are dbh toare)             |
|             |                                                             |
| 111         | All addresses are adknowledged except # Creserved addresses |



The I²C slave can acknowledge several slave addresses. The slave addresses are programmed into two registers. Own Address Register 1 can be programmed with a 7- or a 10-bit address. Own Address Register 2 can be programmed with a 7-bit address, but the Least Significant Bits of this address can be masked through the OA2MSK register, in order to acknowledge multiple slave addresses. The two Own Address Registers can be enabled simultaneously.



The I<sup>2</sup>C peripheral supports Wakeup from Stop mode on address matches. To do this, the I<sup>2</sup>C peripheral clock must be set to the HSI16 oscillator. Only the analog noise filter is supported when the Wakeup from Stop feature is enabled. All addressing modes are supported.

When the device is in Stop mode, the high-speed internal oscillator is switched off. When a Start condition is detected, the I<sup>2</sup>C peripheral enables the high-speed internal oscillator, which is used to receive the address on the bus.

After an address is received in Stop mode, a wakeup interrupt is generated if the address matches the programmed slave address.

If the address does not match, the high-speed internal oscillator is switched off, no interrupt is generated, and the device remains in Stop mode.

Clock stretching must be enabled because the I<sup>2</sup>C peripheral stretches the clock line low after the Start condition, until the high-speed internal oscillator is started. After having received

an address that matches the programmed slave address, the I<sup>2</sup>C peripheral also stretches the clock line low until the STM32L5 device is awaken.

# Simple master mode management

### For payloads <= 255 bytes: only 1 write action needed!

- START = 1
- · SADD: slave address
- RD WRN: transfer direction
- NBYTES = N: number of bytes to be transferred
- AUTOEND = 1 (in the I2C\_CR2 register): STOP automatically sent after N data

| AUTOEND               | Description                                                                                                                                                                                                 |
|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0: Software end mode  | End of transer sofware control after NBYTES bytes of data are transerred: Transfer Complete (TC) fag is set and an interrupt generated if enabled. A Restart or Stop condition can be requested by sofware. |
| 1: Automatic end mode | Stop condition is automatically sent after NBYTES bytes of data are transferred.                                                                                                                            |



Master mode software management is very simple. Only one write action is needed to handle a master transfer with a payload smaller than 255 bytes. The full protocol is managed by the hardware.

In order to start a transfer in Master mode, I<sup>2</sup>C Control Register 2 must be written with the Start condition request, the slave address, the transfer direction, the number of bytes to be transferred, and the End of Transfer mode. End of Transfer mode is configured by the AUTOEND bit. If it is set, the Stop condition is automatically sent after the programmed number of bytes is transferred. If the AUTOEND bit is not set, the end of transfer is managed by software. After the programmed number of bytes is transferred, the Transfer Complete (TC) flag is set and an interrupt is generated, if enabled. Then a Repeated Start or a Stop condition can be requested by software. The data transfer can be managed by interrupts or by the DMA.

# Easy to use event management

- For payloads > 255: The RELOAD bit must be set in I2C\_CR2.
- AUTOEND = 0 (in the I2C\_CR2 register) has no effect when the RELOAD bit is set

| RELOAD         | Description                                                                                                                                                                 |
|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0: No reload   | NBYTES bytes of data are transferred, followed by STOP or RESTART.                                                                                                          |
| 1: Reload mode | NBYTES is reloaded after NBYTES bytes of data are transferred: data transfer will resume.  Transfer Complete Reload (TCR) fag is set and an interrupt generated if enabled. |



When the payload is greater than 255 bytes, the RELOAD bit must be set in I<sup>2</sup>C Control Register 2. In this case, the Transfer Complete Reload (TCR) flag is set after the programmed number of bytes has been transferred. The additional number of bytes to be transferred is programmed when the TCR bit is set, and then, the data transfer will resume. The I<sup>2</sup>C clock is stretched low as long as the TCR bit is set. The RELOAD bit is used in Master mode when the payload is greater than 255 bytes, and in Slave mode when Slave Byte Control is enabled.

When the RELOAD bit is set, the AUTOEND bit has no effect.

- By default: I<sup>2</sup>C slaves use clock stretching. Clock stretching can be disabled by software.
- Reception : Acknowledge control can be done on selected bytes in Slave Byte Control (SBC bit in the I2C\_CR2 register) mode with RELOAD = 1
  - SBC = 1 enables the NBYTES counter in Slave mode (Tx and Rx modes).
  - SBC = 1 is allowed only when NOSTRETCH = 0.

| SBC            | Description                                                                                                                                                                 |
|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0: No reload   | NBYTES bytes of data are transferred, followed by a STOP or RESTART.                                                                                                        |
| 1: Reload mode | NBYTES is reloaded after NBYTES bytes of data are transferred: data transfer will resume.  Transfer Complete Reload (TCR) fag is set and an interrupt generated if enabled. |



By default, the I<sup>2</sup>C slave uses clock stretching. The clock stretching feature can be disabled by software.

In Receive mode, the slave acknowledge on received byte behavior can be configured when Slave Byte Control mode is selected, together with the RELOAD bit being set. When the SBC bit is set, the number of bytes counter is enabled in Slave mode. Clock stretching must be enabled when Slave Byte Control is enabled.

In Receive mode, when Slave Byte Control is enabled with the RELOAD bit set and the number of bytes to be transferred is 1, the Transfer Complete Reload flag is set after each received byte and the SCL line is stretched. This is done after data reception and before the acknowledge pulse. The Receive Buffer Not Empty flag is also set, so the data can be read. In the TCR subroutine, an Acknowledge or NOT Acknowledge can be programmed to be sent after the byte is received.

It is recommended to clear the SBC bit in transmission, as

there is no use for the byte counter in I<sup>2</sup>C Slave Transmitter mode.

In SMBus mode, Slave Byte Control mode is used in transmission for sending the PEC (packet error code) byte.

### Seamless SMBus 3.0 support

- ARP (Address Resolution Protocol): Device default address, Arbitration in slave mode
- Host Notify protocol support: host address
- Alert support: Alert pin and Alert Response support
  - · Timeout and bus idle detection
- Command and data acknowledge control in SBC mode
- Packet Error Checking (PEC) hardware calculation



The I<sup>2</sup>C peripheral provides hardware support for the SMBus. The SMBus Address resolution protocol is supported through the device default address and arbitration in Slave mode.

The Host Notify protocol is supported with host address support.

The Alert protocol is supported through the SMBus Alert pin and Alert Response address.

The SMBus clock low timeout and Cumulative clock low extend times can be detected, with a programmable duration. The Bus Idle condition can be detected with a programmable duration.

Command and data acknowledge control is supported through Slave Byte Control mode.

The Packet Error Code (PEC) byte is calculated by hardware.

# SMBus: PEC (Packet Error Checking)

- Automatic PEC sending/checking
- NBYTES (data transfer counter) is used to:
  - Automatically checks the Packet Error Code (PEC) byte in reception, after NBYTES-1 bytes are received
    - · Automatic NACK sending in case of failure
  - Automatically sends the Packet Error Code (PEC) byte in transmission, after NBYTES-1 bytes are sent
  - Slave Byte Control mode (SBC bit) must be set to Slave mode to enable the NBYTES counter



The Packet Error Code (PEC) byte is automatically sent in transmission, and checked in reception.

The data transfer counter, initialized with the NBYTES value, is used to automatically check the PEC byte in reception, after NBYTES minus one byte are received. If the received PEC byte does not match the calculation, a Not Acknowledge is automatically sent after the PEC byte. In transmission, the internally calculated PEC byte is automatically sent after NBYTES minus one byte. Slave Byte Control mode must be enabled in Slave mode in order to enable the NBYTES counter and allow automatic PEC reception or transmission.

## 

| Interrupt event                     | Description                                                                      |
|-------------------------------------|----------------------------------------------------------------------------------|
| Receive buffer Not Empty            | Set when the Receive buffer contains received data and is ready to be read       |
| Transmit buffer Interrupt<br>Status | Set when the Transmit buffer is empty and is ready to be written.                |
| Stop detection                      | Set when a Stop condition is detected on the bus.                                |
| Transfer Complete Reload            | Set when RELOAD = 1 and NBYTES bytes of data have been transferred.              |
| Transfer Complete                   | Set when RELOAD = 0, AUTOEND = 0 and NBYTES bytes of data have been Transferred. |
| Addless matched                     | Set when the received slave address matches one of the enabled slave addresses.  |
| NACK reception                      | Set by hardware when a NACK is received after a byte transmission.               |



 DMA requests can be generated when the Receive Buffer is Not Empty or when the Transmit buffer is *Empty* 

Several events can trigger an interrupt:

The Receive Buffer Not Empty flag is set when the receive buffer contains received data and is ready to be read. The Transmit Buffer interrupt status is set when the transmit buffer is empty and is ready to be written. The Stop Detection flag is set when a Stop condition is detected on the bus.

The Transfer Complete Reload flag is set when the RELOAD bit is set and NBYTES bytes of data have been transferred. The Transfer Complete flag is set when the RELOAD and AUTOEND bits are cleared and NBYTES bytes of data have been transferred.

The Address Match flag is set when the received slave address matches one of the enabled slave addresses. The NACK reception flag is set when a Not Acknowledge is received after a byte transmission.

DMA requests can be generated when the Receive Buffer Not Empty or Transmit Buffer Empty flag is set.

### Error interrupts 16

| Interrupt event           | Description                                                                                                                                                                     |
|---------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bus Error Detection       | Set when a misplaced Start or Stop condition is detected.                                                                                                                       |
| Arbitration Loss          | Set in the event of an arbitration loss.                                                                                                                                        |
| Overrun/Underrun error    | Set in Slave mode with NOSTRETCH = 1, when new data is received while the previous byte has not yet been read or when new data must be transmitted while it is not written yet. |
| SMBus: PEC error          | Set when the received PEC does not match the PEC register content.                                                                                                              |
| SMBus: Treout error       | Set when a timeout or extended dock timeout occurred.                                                                                                                           |
| SMBus: Abrt pin detection | Set when SMBHEN = 1 (SMBus host configuration), ALERTEN = 1 and a SMBALERT event (falling edge) is detected on SMBA pin.                                                        |



Several errors flags can be generated.

A Bus Error Detection flag is set when a misplaced Start or Stop condition is detected. The Arbitration Loss flag is set in the event of an arbitration loss. An Overrun or Underrun Error flag is set in Slave mode with clock stretching disabled, when an overrun or an underrun error is detected. In SMBus mode, a PEC Error flag is set when the received PEC does not match the calculated PEC register content. A Timeout Error flag is set when a timeout or extended clock timeout is detected. An Alert pin detection flag is set in the SMBus Host configuration, when Alert is enabled and a falling edge is detected on the SMBA pin.

### Low-power modes 17

| Mode               | Description                                                                                                                                                                                                                             |
|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Run and LP Run     | Adive.                                                                                                                                                                                                                                  |
| Sleep and LP Sleep | Adive. Peripheral interrupts cause the device to exit Sleep mode.                                                                                                                                                                       |
| Stop 0, 1          | Registers content is kept. If wakeup from Stop is supported and enabled (WUPEN = 1), and if the I2C is docked by HSI16: the address recognition is functional. The I2C address match condition causes the device to exit the Stop mode. |
| Stop 2             | Only IC3 can generate a wakeup interrupt in case of address match.                                                                                                                                                                      |
| Standby            | Powered-down. The peripheral must be reinitialized after exiting Standby mode.                                                                                                                                                          |
| Shutdown           | Powered-down. The peripheral must be reinitialized after exiting Standby mode.                                                                                                                                                          |



The I<sup>2</sup>C peripheral is active in Run and Sleep modes. In Stop modes, the registers' content is kept. If wakeup from Stop is supported and enabled, and if the I2C is clocked by HSI16: the address recognition is functional. The I2C address match condition causes the device to exit Stop 0 and Stop 1 modes.

Only IC3 can generate a wakeup interrupt from Stop 2 mode in case of address match.

In Standby and Shutdown modes, the peripheral is powered down and must be reinitialized after exiting from these modes.

# Debug information 18

- DBG\_I2Cx\_STOP:
  - 0: normal operation. I2C2 SMBUS timeout continues to operate while CPU is in debug mode.
  - · 1:stop In debug. I2Cx SMBUS timeout counter is stopped when core is halted



For each I<sup>2</sup>C peripheral, a bit is available for debugging purposes in the MCU Debug Component that can be used to stop the SMBUS timeout counter when the core is halted.



#### **Sensor Hub**

- I<sup>2</sup>C master in Sleep mode to communicate with sensors
- I<sup>2</sup>C slave to communicate with application processor.





Here is an example of a sensor hub application that requires several I<sup>2</sup>C peripherals.

One or several I<sup>2</sup>C masters are used to interface with external sensors. An I<sup>2</sup>C slave is used to communicate with the application processor.

### STM32L5 instances features 20

| I <sup>2</sup> C features                                    | I2C1 | 12C2 | I2C3 | 12C4 |
|--------------------------------------------------------------|------|------|------|------|
| 7-bit addressing mode                                        | Х    | Х    | Х    | Х    |
| 10-bit addressing mode                                       | Х    | X    | X    | Х    |
| Standard-mode (up to 100 Kbifs)                              | X    | X    | X    | X    |
| Fast-mode (up to 400 Kbits)                                  | Х    | Х    | X    | Х    |
| Fast-mode Plus with 20 mA cutput drive l'Os (up to 1 Mbit's) | Х    | Х    | X    | Х    |
| Independent cbck                                             | Х    | Х    | X    | Х    |
| Wakeup from Stop 1 mode                                      | Х    | X    | Х    | Х    |
| Wakeup from Stop 2 mode                                      | -    | -    | X    | 2    |
| SMBus                                                        | X    | Х    | Х    | Х    |

x: supported



STM32L5 microcontrollers embed four I<sup>2</sup>C peripherals, all with the same set of features, except for the IC3 port which is the only instance supporting wake up from Stop 2 mode. The I2C address match condition causes the device to exit Stop 0 and Stop 1 modes.

Only IC3 can generate a wakeup interrupt from Stop 2 mode in case of address match.

# Related peripherals 21

- · For more information, refer to these trainings linked to this peripheral:
  - System Configuration Controller (SYSCFG)
  - Reset and Clock Controller (RCC)
  - Power controller (PWR)
  - Interrupts (NVIC and EXTI)
  - · Direct memory access controller (DMA)



For more information related to this peripheral, you can also refer to these trainings:

- System configuration controller
- Reset and Clock controller
- Power controller
- Interrupts controller
- Direct memory access controller

### References 22

- For more details, please refer to following webpages:
  - www.nxp.com :
    - UM10204 I2C-bus specification and user manual
  - www.sbs-forum.org
    - · System Management Bus (SMBus) Specification
  - http://www.powersig.org/
    - · PMBusTM Power System Management Protocol Specification



For more details, please refer to the I<sup>2</sup>C-bus specification and user manual from the NXP web site.

The SMBus specification can be found in the Smart Battery System implementers forum.

The PMBus Power System Management Protocol specification can be found in the Power Management Bus implementers forum.